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INTERACTIVE COMPUTER SYSTEM WITH 
5 MULTI-PROTOCOL CAPABILITY 

This application is a continuation-in-part of U.S. 
Patent Application Serial No. 08/037,220, filed March 26, 

10 1993, U.S. Patent Application Serial No. 08/086,701, filed 

July 2, 1993, U.S. Patent Application Serial No. 07/995,798, 
filed December 23, 1992 and 07/819,489 filed January 19, 1992, 
all of which are incorporated herein by reference. 

The present invention relates to an interactive 

15 computer system for routing calls, inquiries, or requests to a 
preferred one of a plurality of application programs for 
filling or answering the inquiry or request. In particular, 
the present invention provides a computing system which can 
accommodate a variety of protocols and media, for such 

20 requests and such applications, including telephone requests, 
faxed rec[uests, interactive video cable requests and the like, 
and routing the requests to a variety of applications such as 
applications for providing product information, filling orders 
for products or providing or processing coupons. 

25 

BACKGROUND OF THE INVENTION 
Various systems have been used for filling or 
answering requests for inforaation or products. Some systems 
are at least partially automated. One example is a voice mail 

30 system in which a person wishing to leave a message can do so 
in an entirely automated fashion via telephone, making 
selections using the telephone keyboard to send dual tone 
multi-frequency (DTMF) signals to select options for recording 
messages. Another example, is an electronic bulletin board in 

35 which an operator of a personal computer can select to view, 

upload or download information to or from a remote computer by 
making keyboard selections which are transmitted to the 
remote, typically via a modem/ telephone link. Yet another 
example is sending or receiving of information or messages 
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between two computers via electronic mail or "e-mail" systems, 
e.g., over a local area network (LAN). 

Although these various examples have certain 
features in common (such as routing of information between 
5 remote cites) each system has typically been developed 

independently and each represents, in a sense, a "customized" 
system. Thus, as each such system is developed, it has been 
infeasible to take advantage of the development effort made in 
other systems and this has contributed to the large 

10 development time and development cost associated with 

establishing such systems. Furthermore, as new technologies 
have become available (such as, for example, wireless 
networks) or as new communication/ computing platforms have 
become available (such as, e.g., personal communication 

15 devices) new systems for communicating with remote locations 
and transferring information back and forth have been 
developed independently and customized to the new medium or 
platform. 

Furthermore, because various communication media 

20 platforms each have their own communication protocols, it has 
been difficult to provide a system to accommodate multiple 
media or platforms and, in cases where this has been 
attempted, the system has typically been customized so that 
little benefit arises from previous development work when 

25 accommodating a new protocol in a system- Furthermore, the 

manner in which a user or customer interfaces, has had little 
consistency from one system to the next so that the user or 
customer must learn and remember the user interface and 
procedures peculiar to each system that the user works on. 

30 Additionally, previous systems of this type have 

required intenisive user input in order to determine the 
information suitable for the user, typically requiring the 
user to expressly request the information and to input the 
data needed to accomplish the communication and to fulfill the 

35 request or order. Often this means that the user, in order to 
receive the best or most desirable service from the system, 
must have considerable knowledge about the system, the various 
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resources that are available and the capabilities of the 
various resources. 

Accordingly, it would be useful to provide a system 
in which information can be routed between users of the system 
5 and the programs for processing the user data to fulfil the 
user requests which can accommodate a plurality of data 
communication protocols and communication platforms and can be 
more readily modified to accommodate new types of protocols 
and platforms. It will be useful to lower the amount of 

10 development cost and time needed to achieve such modification. 
It would also be useful to provide a degree of consistency for 
the user so that procedures learned in connection with one 
platform or communication medium are sufficiently similar to 
the user interface for another platform or medium that a new 

15 medium or platform can be used with a minimum of learning. It 
would also be useful to provide a routing device which has the 
intelligence needed to route the user's request to the best 
resource available for handling the request, preferably while 
minimizing the amount of manual input required from the user 

20 and minimizing the amount of knowledge the user must have 
about the system and its resources. 

SUMMARY OF THE INVENTION 
According to the present invention, a routing 

25 system, preferably a programmed computer, mediates between a 
communications or I/O facility and a data processing or 
applications facility. The routing facility does not receive 
and transmit data directly from and to the various 
communication media (such as telephone switches or lines, 

30 telefax server, etc.). Instead, a plurality of generic 
interfaces are provided to convert various commxihication 
protocols into generic communication protocols. Thus, the 
routing facility can use the same logic for a plurality of 
different protocols and/or platforms. This provides a number 

35 of advantages. By using the conversion capability provided by 
the I/O facility, the routing facility can easily accommodate 
a new type or protocol or platform or medium since only the 
I/O facility needs to be updated to accommodate the new 
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platform or protocol, with the routing facility requiring 
little or no modification. Similarly, enhancements or 
revisions of the routing facility can be easily achieved since 
it is not necessary to accommodate the peculiarities of the 
5 various protocols or platforms, but only the generic I/O 
interface facilities which would be fewer in number and, 
preferably, at least partially consistent with one another. 

The generic interfaces provide the opportunity to 
easily achieve a standard user interface which can provide 

10 some consistency between various platforms. In this way, a 
user who is accustom to making requests and receiving 
information using a telephone keypad will easily be able to 
use the system via an e-mail procedure since the telephone 
generic I/O interface is preferably similar to the e-mail 

15 generic I/O interface and since the common routing logic and 
common applications resources will already be familiar to the 
user. 

In a similar fashion, the data processing modules or 
applications which service the user requests are connected to 
20 the routing facility via generic application interfaces. This, 
facilitates the modification, enhancement, or addition of 
applications to the system since this can be little or no 
modification of the routing facility. Providing an amount of 
consistency between the various generic application interfaces 
25 also contributes to the user's perception of consistency and 
ability to adapt from one application to another. Thus, the 
user can more easily enjoy the benefits of various types of 
applications with minimal amount of relearning, while those 
responsible for development of the application software do not 
30 need to be concerned with the issue of consistency since this 
is attended-to the generic application interfaces. 

In this fashion, the routing or management system, 
which is preferably a multi-media system, provides for 
management of transactions without regard to the type of 
35 communication medium (e.g., voice, fax, video). The system 
uses a routing or communication protocol layer and generic 
interface layers permitting implementation of new protocols or 
platforms as they become available. 
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In one embodiment, the routing facility uses an 
object-based database to maintain information about the 
transactions, both for current tracking and routing and for 
future statistical information. 

one embodiment of the present invention involves an 
interactive computing system for facilitating sales of goods 
and services or matching individuals with common interests and 
for gathering information, which provides a facility for 
representing the interests or characteristics of the users of 
the system so as to automatically gather pertinent information 
and direct information to recipients who are likely to be 
interested in the information. In one embodiment, the 
interactive computer system generates one or more database 
entries and associated procedures, referred to herein as 
15 -agents- to represent the interests or characteristics of the 
users of the system as well as the interests of the system. 
An -agent" is not restricted to representing an individual. 
An agent can be formed to represent, for example, a household, 
a company, a neighborhood, etc. Each agent includes a portion 
20 of memory for storing information, in a predetermined fashion, 
relating to the likely interests, purchase histories, 
demographic and other information, communications preferences, 
shipping and billing preferences, etc. of a user. Each agent 
also includes, a communication facility for conveying 
25 information to users of the system and one or more predefined 
procedures for identifying and selecting information which 
fits the stored interest profile for that agent, so that the 
information can be transmitted to the user. The system 
provides for activation of agents at predetermined times or 
30 after predetermined events. 

Unlike advertising systems which are based on 
general demographic, information, the present system is able to 
store characteristics or preferences associated with persons 
who have actively initiated some communication with the 
system, such as using electronic communication like telephone 
communication, telefax communication, modem communication and 
the like. This increases the likelihood that responses which 
are provided back to the user will be of interest to the user 



35 
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(as apposed to advertising which is sent to a predefined 
demographic group that may or may not have an interest in a 
product, service, person or the like). Furthermore, by 
building agent portfolios for those who have initiated or 
5 positively responded to communications in the system, it is 
possible to provide an interactive computing system which can 
be configured either to provide information only in response 
to a request for information from the user or to provide 
unsolicited information to persons about whom the system has 

10 stored interests or characteristics. 

In one embodiment, a database stores information 
about each customer of a company, which includes information 
about the likely interest of the customer, such as past 
product purchases, demographic information, customer inquiries 

15 and the like. At certain times (such as when new products are 
added to the company's line, or as prices change, sales or 
other promotions are announced, upon request by the customer, 
when the customer places an order, or at periodic intervals) , 
the customer's agent prepares a "catalogue" of company 

20 products which is preferably individualized, i.e., which is 

limited to, emphasizes, or is weighted toward the, items which 
are of likely interest to the customer. Thus, the customer 
does not bear the burden of reviewing large amounts of 
advertising for items which are of little interest, since the 

25 customer's interests and/or characteristics have been 

represented by his electronic agent, who has produced an 
individualized catalogue. The catalogue can be sent by any of 
a number of communication facilities, including by phone, fax, 
modem, mail, or video preferably using a medium that has been 

30 tailored to the preferences or characteristics of the user, in 
reliance on information stored using the user's agent. 

In addition, the seller can establish procedures for 
packaging/ shipping a product using information about the 
buyer, obtained from the buyer's agent. For example, if the 

35 agent indicates that the buyer has access to telephone 

services, a product which is purchased can be packaged with 
automated telephone information, to, e.g., offer the buyer the 
opportunity to use his telephone to automatically perform 
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product registration, obtain installation, use instructions, 
obtain further product infonnation, contract for extended 
warranty /maintenance services. In the present context 
..telephone., refers generally to communication at a distance, 
5 and includes not only voice communication over a standard 
land-line network, but also cellular phone communxcation, 
telefax communication, computer and/or modem communxcatxon, 
wireless network communication, cable communication, personal 
digital assistant communication and the like. If the agent 
10 indicates that the buyer has access to video service, the 
buyer can be offered the opportunity to receive vxdeo 
information or advertising and, if the video is interactive, 
to perform product registration, etc. If the agent indicates 
the buyer prefers to communicate using a personal computer 
15 (PC) , personal digital assistant (PDA) , fax, or other 

ro^;nLtions means, the product and associated offers can be 

packaged accordingly. 

The information regarding user preferences and 
Characteristics can be obtained in a number of fashions. In 
20 one embodiment, advertising (which can be print 

electronic advertising, visual or aural advertising and the 
like) is provided with one or more advertising code numbers. 
Vft,en a user of the system wishes to place a order for an 
advertised product or wishes to obtain further information 
25 about the product or related or similar products, the user can 
access the interactive computing system of the present 
invention and provide the computer system with the advertising 
code number or numbers. This accomplishes a number of 
purposes. First, the system contains a database which 

30 - co^elates the advertising code number with information about 

the contents of the advertising. Thus, if the <=-^-- - 
attempting to order the advertised product, the system knows 
t:i::Ltely what product or products the user may - ---^ 
and the task of receiving the order is simplified. Similar y 
35 if the user is requesting further information on a product 
products or services the system can readily identify the 
products and provide the proper information to the user, based 
. L the code number which has been provided. Furthermore, the 
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code can be correlated with the medium, time and place of the 
advertising to obtain information about the characteristics of 
the user such as what publications, programming, locations and 
times are read, visited or frequented by the user -"^J^^^ 
Information can be used to more accurately provide information 
which is likely to be of interest to the user. 

A system as described above can provide a number of 
facilities and capabilities in addition to providing the 
information and facilitating buying/ selling. In one 
embodiment, an application utilizes information about the 
customer or the customer's order (either retrieved from a 
database or on the basis of information entered by the 
customer) so that a caller can, by entering, e.g., an order 
number or a product number be told when a product - ^^P-^^^ 
to be available or an order is expected to be shipped. The 
application can be used to provide information to a caller 
concerning retail outlets such as using a caller's zip code or 
telephone number (either entered by the number or -^"-^^ 
using automatic number identification (ANI) ) to determined the 
closest retail store and provide directions, address, phone 
number, and store hours by voice or fax. The application can 
be used to deliver ordered goods directly when the goods are 
capable of electronic transmission (such as downloading 
ordered software via modem) . 

The system is preferably configured to accommodate 
and respond to changes in the flow of demand on the system 
e.g., to route requests to an application which is available, 
even if the application is not optimal, in other senses, for 
filling the user's request. In situations where the user 
enters the system via a voice phone call, the system may 
decide to route the call to a facility or person who is 
presently too busy to take the call- current systems handle 
this situation by placing the caller on hold or, in some 
cases. Offering the user a different facility such as an 
automated information or ordering facility. According to one 
embodiment, a user can interact with various automated 
services simultaneously while waiting on-hold for the desired 
person or service, without the user losing his or her place in 
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the queue for such service. The interactive on-hold service 
can include a choice of music, which, preferably, the user 
could change anytime (by pressing corresponding numbers on the 
telephone keypad) , and/or a series of vendor-paid 
advertisements, preferably that the caller can browse through 
by skipping or repeating various advertisements, using the 
touch tone keypad and the like. Interactive on-hold services 
can be provided in connection with video or tele-video 
communication as well as audio communications. 
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BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 is a schematic block diagram of an 
interactive computer system coupled to input and output 
devices ; 

Fig. 2 is a schematic block diagram of an 
interactive computer system, according to one embodiment of 

the present invention; 

Fig. 3 is a flow diagram depicting a generalized 
scheme for responding to user input in an interactive computer 
system, according to one embodiment of the present invention; 

Fig. 4 is a flow chart showing the handling of an 
incoming call, according to one embodiment of the present 
invention; 

Fig. 5 is a flow chart illustrating the placement of 
a new ad or product description, according to one embodiment 
of the present invention; 

Fig. 6 is a flow chart illustrating a search for 
matching interests, according to one embodiment of the present 
invention; 

Fig. 7 is a flow chart illustrating a callback 
routine, according to one embodiment of the present" invention; 

Fig. 8 is a flow chart illustrating steps performed 
when a buyer requests a catalogue, according to one embodiment 

of the present invention; 

Fig. 9 is a flow chart illustrating catalogue item 
playback, according to one embodiment of the present 
invention; 
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Fig. IP is a flow chart illustrating activation of 
an agent to select items for a catalogue, according to one 
embodiment of the present invention; 

Fig. 11 is a flow chart illustrating operation of a 
5 unified system including self-publishing catalogue, coupon 
handling, catalogue orders and virtual gift cards, according 
to one embodiment of the present invention; 

Fig. 12 is a flow chart illustrating a procedure for 
ordering from a catalogue, according to one embodiment of the 

10 present invention; 

Fig. 13 illustrates a procedure for establishing a 
new agent, according to one embodiment of the present 
invention; 

Fig. 14 illustrates a procedure for modifying an 
15 existing agent, according to one embodiment of the present 
• invention; 

Fig. 15 illustrates a procedure for screening calls 
in an interactive system, according to one embodiment of the 

present invention; 

Fig. 16 is a flow chart of a method for automatic 
shopping, according to an embodiment of the present invention; 

Fig. 17 is a block diagram of an interactive 
computer system with multi-protocol capabilities according to 
one embodiment of the present invention, along with a 
25 plurality of communication platforms; and 

Fig. 18 depicts an on-hold or automated processing 
system according to previous devices; 

Fig. 19 depicts an interactive on-hold system 
according to an embodiment of the present invention; 
3Q rig. 20 depicts an "estimated time of arrival- 

procedure according to an embodiment of the present invention; 

Fig. 21 depicts a locator application according to 
an embodiment of the present invention; and 

Fig. 22A-22D depict a unified system including 
35 catalogue browsing functions, ordering functions, and locating 
functions according to an embodiment of the present invention. 
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DESCRIPTION OF THE PREFERRED EMBODIMENT 
Fig 17 is a block diagram of an interactive 
computer system with multi-protocol capability according to an 
embodiment of the present invention. The system is configured 
5 to route information between a plurality of data nodes 1702- 
1726 and a plurality of information processing applications 
1728a-1728i. The data nodes 1702-1726 are various 
communication platforms, at least some of which allow user to 
access to the system 1701. A variety of different data nodes 
10 or platforms can be used to access the system 1701 and/or to 
provide output from the system 1701. Examples depicted in 
Fig. 17 include a fax server 1708, interactive voice response 
systems, e.g., Linkon", IVR Systems, or Periphonics™, 
interactive voice response system 1712, relational database 
15 systems such as an Informix™ relational database management 

system (RDBMS) 1714 or various other customer database systems 
1716, Object-oriented database systems such as SERVIO™ ob^ect- 
oriented database management systems 1718, various on-line 
services such as the Newton" 1720, e-mail 1722, American On- 
20 Line" (AOL) , existing data communications systems such as 
X 25 local area networks (LANs) or the proposed National 
info^ation Highway 1724 and video services including cable, 
fiber-optic and broadcast video services 1726. Some or all of 
these may be, in turn coupled to a further communication link 
25 1730 such as telephone line, cable, fiber optic system and the 
like. 

variety of information processing systems or 
applications can be used, typically each being a software 
package designed to receive requests for information or action 

30 and to fill the requests. In addition to various types of 

classified ad systems 1728a, 1728b, examples of applications 
depicted in Fig. 17 include catalogue applications 1728c, 
1728d, either for providing product descriptions in response 
to user requests or other events or to permit ordering of 

35 goods or services, as described, for example, in U.S. Serial 
NO. 08/086,701, filed July 2, 1993, and "On-Hold" application 
for providing services to users while users are waiting for 
another service, as described more fully below, a location 
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application such as an application for providing a store 
location or a representative location 1728f , 1728g described 
more fully below, and a report application I728h, 1728i, e.g., 
for providing statistical information such as information on 
5 sales, orders, or demographic information gathered by the 
system. 

AS one example of a user of the system, user A may 
wish to use an electronic classified system for finding a new 
car. using the system 1701, user A can enter the system via 

10 telephone using any of a variety of telephone services such as 
telephone switch card 1702, Mitel™ switch 1704, AT&T Definity 
switch 1706, and the like. Typically, the user will access by 
dialing a number using his or her home telephone. Using 
methods described more fully below, the system 1701 will 

15 receive the call and route it to a classified ad application 
1728a. The classified ad application 1728a includes software 
for accessing one or more advertising databases, performing a 
search and outputting results. The results of the search will 
then be routed back to user A, either via the telephone 

20 switches 1702-1706 or through another route, defined by the 
user. A classified ad application of this nature is 
described, for example, in U.S. Serial No. 07/819.484. filed 

January 19, 1992. ' 

A computing system 1732 is provided for routing data 
25 such as request for services and responses to requests between 
the data nodes 1702-1726 and various applications 1728a-1728i. 
However, the computer 1732 does not communicate directly with 
the data nodes 1702-1726 or the applications 1728a-1728i. 
instead, the computer 1732 communicates with the data nodes 
30 via a plurality of generic I/O interface devices 1734a-1734g. 
1736. The computer 1732 communicates with the applications 
via a plurality of generic application interface devices. 

preferably, the generic interfaces I734a-1734g, 
1736, I738a-1738e are software packages. Although Fig. 17 
35 depicts the interfaces as separate blocks, they may be 

executed on the computer 1732, or may be executed on separate 
computing devices. In addition, the generic I/O interfaces 
1734a-1734g include physical layer interfaces for converting 
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the different types of signals output by the various platforms 
1702-1726 into signals which can be received and processed by 
the computer 1732. These physical layer devices can include 
digital/analog converters, buffers and timing and control 
circuits of types well-known in the art. 

Each of the various data nodes 1702-1726 receives 
and transmits data according to its own protocol. In general, 
a communication protocol specifies items such as data rate, 
frequencies, synchronous /asynchronous /isochronous nature of 
communication, format for control/routing information and the 
like. 

Fig. 17 depicts a configuration in which several 
different protocols are present. For example, on-line 
services 1724 depicted include both X.25 services (defined by 
15 CCITT Standard X.25) and a local area network which might be, 
for example, a token-ring network defined by IEEE Standard 
802.5. If the computer 1732 were to communicate directly with 
both of these devices, it would be necessary to provide 
separate software in computer 1732 to handle each of these 
20 communications despite the fact that the type of input and 

.output for communicating from the X.25 ethernet channels with 
an application are similar. According to the present 
invention, a generic I/O interface 1734f issues to convert the 
communication from each of the two different-protocol nodes 
25 X.25 and LAN, into a single generic I/O protocol. 

using a generic I/O interface facility has a number 
of useful effects. It reduces the number of protocols which 
the routing computer 1732 must accommodate. It reduces the 
development, time and effort needed to accommodate a new type 
30 of data node. For example, interactive video services are 

still being developed and different types of interactive video 
services with different protocols are likely to arise. 
According to the embodiment of Fig. 17, different types of 
video servers 1726 can be accommodated by modifying only the 
35 generic video I/O interface 17.34g. The software developed in 
the routing facility 1732 for accommodating the generic I/O 
output by the generic interface 1734 does not need to be 
reconfigured as new types of video servers 1726 are developed 



PCT/US93/12540 

WO 94/15294 

14 

Since the protocol of each new type of video server, as it is 
developed, will be translated by a (modified) generic I/O 
video interface 1734g into the same generic video protocol. 

Although Fig. 17 depicts different communication 
5 channels 1742a-1742g for each of the different generic 

interfaces 1734a-1734g, according to one embodiment two or 
more of the various generic interfaces 1734a-1734g can provide 
generic I/O which is identical and thus only one communication 
channel may be needed for two or more I/O interfaces. In this 
10 situation, the programming of the routing computer 1732 can be 
even further simplified since the routing computer can 
communicate with two or more generic I/O interfaces in the 
same fashion, without requiring information as to which type 
of generic I/O interface it is. In the ultimate case, all 
15 generic I/O interfaces will translate into the same generic 

I/O protocol and the routing computer 1732 will communicate to 
and from the generic I/O interfaces without requiring 
knowledge as to whether the interface is, for example, a fax 
interface 1734b or a voice interface 1734c. 
20 in some embodiments, it will be useful to provide 

two or more layers of generic I/O interfaces. For example, as 
depicted in Fig. 17, separate generic I/O interfaces are 
provided for relational databases 1734d and object-oriented 
databases 1734e. Because there are both a number of 
25 similarities and a number of differences in the operation of 
these two types of databases, a second layer of I/O interface 
1736 can be provided to translate generic relational database 
i/0 and generic object-oriented database I/O into a single 
generic database I/O before communication to and from the 

30 routing computer 1732. 

in a similar fashion, generic application interfaces 

convert between data protocols appropriate for the various 
applications 1728a-1728i and a generic protocol for processing 
by the routing computer 1732. In this case, data protocol 
35 between the applications differs primarily as to aspects (such 
as order and/or tagging of data) which determines how data is 
to be handled by the application. For example, classified ad 
application number 1 1728a, may expect the first N words of 
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data to contain a user identifier number while classified ad 
application number 2 1738b, may expect the first M words of 
data to indicate whether the user wishes to place a new ad or 
search the existing ads. The generic classified application 
interface 1738a translates these differing protocols into a 
common generic classified application protocol for processing 
by the routing computer 1732. This reduces the time and 
effort reguired to modify existing applications or to add new 
applications to the system since such a modification or 
addition can be done in conjunction with modifying a generic 
application interface I738a-1738e without needing to modify 
the routing computer programming 1732. Since different 
classified ad applications 1728a, 1728b are converted into a 
common protocol for handling by the routing computer 1732, the 
15 different applications have a similar appearance to the user, 
making it easier for the user to move from one application to 
the next. This continuity of appearance can be enhanced when 
the generic protocols provided by the various generic 
application interfaces I738a-1738e are similar to one another 
20 thus malcing it easier for the user to move from, for example, 
a classified ad application to a catalogue application. 

The routing computer 1732 preferably provides 
functions beyond passively routing communications to 
applications which are requested expressly by the user. In 
25 one embodiment, the user is not required to be familiar with 
the various applications 1728a-1728i available through the 
system. Instead, the user merely requests the information, 
product or service desired and the routing computer 1732 
selects the application best suited to the request. In one 
30 embodiment, the routing computer 1732 maintains (or has 

accessible) a database containing information regarding the 
caller, including the caller's request and also maintains (or 
has accessible) information regarding the capabilities and 
resources of the various applications that are available. The 
35 information regarding the caller can be based on a number of 
sources including the information expressly input by the 
caller, either spontaneously or in response to prompts output 
by the' routing computer 1732 as well as information obtained 
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without express user input, such as telephone information from 
an automatic number identification (ANI) system, data source 
information received through an e-mail system and the like. 
Further, the system can be configured to access information 
about various past and/or potential callers. For example, 
information about past callers may include past merchandise 
orders, past information requests and the like. Information 
accessed about a past or potential caller might include, for 
example, demographic information about the location where the 
caller is calling from (such as average income, education, 
etc), credit history information, and the like. Information 
regarding the capabilities and the uses of the various 
applications can include information regarding the demographic 
profile of target or usual customers, types of merchandise 
available, average cost of merchandise, acceptable payment 
forms and the like. A routing computer 1732, in this 
embodiment, performs a closeness-of-f it analysis between the 
user profile and the profile of the various applications 
available. A match can be made on the basis of various 
closeness parameters. For example, one embodiment, may 
attempt to find the application most likely to satisfy the 
user with the greatest rapidity (thus minimizing demand on the 
system 1701) , while another embodiment may match a request to 
that application which has the largest number of resources to 
respond to. the user (which may not provide the most rapid 
response) thus maximizing shopping time and, potentially, 

maximizing purchases. 

in another embodiment of the invention, as depicted 
in Fig. 1, an interactive computer system 1010 is coupled to 
any or all of a plurality of input devices 1012 and output 
devices 1014. The input and output devices 1012, 1014, are - 
coupled to an I/O connect and interface device 1016. The I/O 
connect and interface device can include, for example a fax 
server, a telephone answering and/or switch system, or an 
interactive voice response (IVR) system. The I/O connect and 
interface is coupled to one or more databases 1018 which 
include memory devices for storing database information, a 
database server (which can be, for example, a personal 
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computer, workstation, or mainframe) and associated software. 
The software can be any of a number of commercially available 
database software packages and/ or can be specifically 
programmed for one or more of the embodiments described below. 
Preferably, the I/O connect and interface is also coupled to 
operator facilities 1020 to permit connection of a user to an 
operator, as described below. Operation of the I/O connect 
and interface 1016 and database 1018 is controlled by a 
control device 1022 which can be, for example, a personal 
computer, workstation or mainframe. The control 1022 can be a 
separate unit from the database server or can be the same 
computer. 

The user accesses the interactive computer system 
1010 through any of a plurality of input devices 1012 and 
output devices 1014. Fig. 1 illustrates examples of some 
possible input and output devices, although any I/O devices 
that permit the user to effectively communicate with the 
interactive computer can be used. Telephone input 1024 can be 
via keypad input, particularly in a dual-tone multi-frequency 
20 (DTMF) telephone system, or can rely on voice recognition 

software (typically, e.g., installed in the computer system 
1010) to permit verbal input of data and commands. A telefax 
input can be sent to an operator for manual entry, can be sent 
to a scanner, for example, for detection of check-box 
25 markings, or can be processed by optical character recognition 
(OCR) software to permit faxing of printed, typed or 
handwritten input. A computer can be used for inputting data 
and commands, for example, by using a personal computer 1028 
connected using a dial-up modem, a Local Area Network (LAN) , 
30 or a wireless network (e.g., a radio network). Any of a 

number of styles of computer can be used including, personal 
computers, laptops, palmtops, notebook computers, personal 
digital assistants, workstations and mainframes. The computer 
1028 can accept input through any of a variety of methods, 
35 including keyboard input, mouse input, touch-screen input, pen 
or stylus input, oral or voice-activated or voice-recognition 
input and the like. Input can include card-reader input 1030 
such as facilities for reading encoded cards such as credit 
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cards (e.g., at point-of-purchase) , debit cards, banking 
cards, identification cards, or other item or card readers 
including bar-code readers. Input can also be accepted at 
automatic teller machines 1032 which typically provide both 
5 card readers and keyboards. 

Output from the interactive system 1010 to the user 
can be by a ntunber of output devices including telephone, 
telefax and personal computer. Output can be digital or 
analog and can include audio, video or other information. 
10 Elirther, output facilities such as cable facilities (including 
video and audio cables and/or including wire and optical 
cables) 1034 and mail or other shipping facilities 1036 can 
provide output to the user. In all cases, input and output 
communications can be provided with privacy/ security features 
15 such as encryption and/or password systems. 

A particular implementation of an interactive 
computer system lOlO is depicted in Fig. 2, which illustrates 
a system which can be used in connection with a self- 
publishing catalogue application. The catalogue may include 
20 information regarding products from a single source (such as 
the catalogue for a retail outlet) or can be a compilation of 
products from a number of sources (such as a co-op) . In the 
former case, little information need be stored regarding 
"sellers" since there is only one source. In the latter case, 
25 it may be desired to maintain an extensive database on various 
sellers, as described more thoroughly below. This 
configuration comprises a telephone switch such as PBX 
(private branch exchange) 12, an interactive voice response 
(IVR) system 14, a database server (DBS) 16, and a fax server 
30 18. PBX 12 is connected to one or more telephone lines 20 

through which users (buyers and sellers) amy communicate with 
the system, either by voice or fax. A suitable PBX is the 
Summa/Four™ switch available from Summa. In general, any 
switch capable of responding to control by an external 
35 computer may be used. 

IVR 14 is a computer specialized for storing digital 
audio scripts, and for playing back such scripts in response 
to digital or touch tone inputs. IVR 14 is coupled to PBX 12 



PCT/US93/12540 

WO 94/15294 

19 

via Tl telephone line 22. such that the IVR can be coupled 
directly to a user who calls the system via telephone line 20. 
However, in a preferred implementation of the present 
invention, the IVR preferably includes the ability to 
5 concatenate individual words or phrases to produce voice 
output. 

An IVR with concatenation ability is to be 
contrasted with a simple voice mail system. In a voice mail 
system, one can store a number of voice scripts, and means for 
10 permitting a user to access different scripts depending upon 
touch tones or other data input by the user. Each script, 
however, is a complete message, and cannot be further broken 
down. This limitation means that the individual words and 
other data within the script are not searchable. In contrast, 
15 in an IVR system with concatenation capability, individual 
words and/or phrases are stored in voice form, while the 
messages that will be built up from such words and phrases are 
stored in a conventional text-type database. When a message 
from the database is to be converted into voice form, the IVR 
20 retrieves the voice corresponding to each word or phrase, and 
concatenates these individual voice segments into an output 
voice message. Suitable IVR's with concatenation ability are 
the voice Processing Series (VPS) models available from 
Periphonics, Enhanced Services Platform (ESP) available from 
25 Precision Systems, Inc. and Linkon. 

DBS 16 is a general-purpose computer programmed for 
database operations. In the illustrated embodiment, DBS 16 
manages three text (as opposed to voice) databases: ad • 
database 30, seller database 34, and buyer database 36. Ad 
database 30 comprises an electronic equivalent of the ads 
typically included in a catalogue. Seller database 34 lists 
the sellers that have registered to use the system, while 
buyer database 36 list the buyers that have registered to use 
the system or who are potential buyers. 

The seller and buyer databases also include 
information pertinent to the preferences and interests of the 
buyers and sellers and represent one component of the agent. 
This information is gathered in any of a number of ways. The 
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information may be provided by the user by reference to a code 
number associated with an advertisement such as an 
advertisement or listing in a telephone directory or "yellow 
pages" directory, or an entry in a catalogue. The code number 
may be of a form that it can be readily entered using a 
keyboard (e.g., telephone keypad. Automatic Teller Machine 
(ATM) keypad, computer keyboard) so that the information can 
be obtained without the intervention of an operator. The 
information may be requested at the time the seller requests 
an entry in the catalogue or at the time a buyer calls to 
place an order or make an inquiry. The information may be 
gathered automatically using the IVR system or a computer- 
controlled text script system, or the information may by 
gathered by an operator for manual entry. Preferably, the 
buyer information will include information regarding how the 
buyer wishes to pay for purchases (e.g., credit card 
information), and shipping information (e.g., preferred type 
of shipping, shipping address). The inf or^nation, preferably, 
also includes information related to the actual or likely 
interests of the buyer, such as purchase histories, 
demographic information, expressed interests such as type of 
employment, hobbies, current equipment, and the like. 
Advertising code numbers, e.g. in connection with telephone 
directory listings or in connection with catalogue entries, 
can be used to obtain and store information regarding purchase 
history of the user, previous interest in products or services 
expressed by the user (e.g., in the form of previous 
information requests) , reading or viewing habits of the user, 
and the like. Information may be gathered from the user which 
relates to likely future purchases, such as information about 
birthdays of family members, or other significant events, 
information about previous gifts purchased by this user, 
information about the level of spending for previously- 
purchased products or gifts and the like. In addition to or 
35 in place of gathering information directly from the buyer, 
this information can also be gathered automatically (e.g., 
using telephone caller identification systems) or as a result 
of the users -s inquiries or purchases within the system, or by 
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obtaining the information from a commercial information source 
(such as a commercial mailing list with demographic 
information) . , Similarly, information regarding the advertiser 
or seller can be gathered, including information regarding the 
5 history of ad placements or catalogue entries and the like. 

in one embodiment, information about the user is accessible to 
more than one system so that, for example, once a caller has 
entered his address and phone number in a given system, other 
systems will be able to use this information (keyed, for 
10 example, to a user identifier number) . Preferably, thxs 

aspect of the invention is implemented by having a central 
repository for such information which is accessible by a 
plurality of systems. A central repository simplifies the 
process of changing an address, phone number, etc. as this 
15 data changes for an individual user. 

DBS 16 is coupled to IVR 14 via serial link 24, and 
to PBX 12 via serial link 26. The DBS includes terminal 40 
through which an operator can interact with and control the 
DBS. Terminal 40 may be a conventional personal computer. 
20 The operator of terminal 40 wears headset 42 that includes, 
headphones 44 and microphone 46. The headset is coupled to 
PBX 12, so that the operator can engage in conversations with 
callers via the PBX and telephone line 20. 

Fax server 18 is coupled to PBX 12 via telephone 
25 line 50, and to DBS 16. via serial line 52. The fax sever may 
be a conventional personal computer with a fax board. 

The operation of the system shown in Fig. 2 is 
outlined in the flow charts of Figs. 3-13. The general 
operation of an interactive system is depicted in Fig. 3 
30 -I/O connect/interface system 1016 receives an initial input 
such as by answering a telephone call or computer modem call 
1042 The I/O connect interface system 1016 sends a short 
introductory audio or video message to the user, briefly 
explaining how to operate the system and preferably inviting 
35 the inexperienced user to request more detailed information 
1044 The I/O connect/interface system 1016 monitors the 
input from the user and in particular checks for user input 
which indicates the user is requesting help 1046 or is 
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requesting to be connected to an operator 1048, whereupon the 
I/O connect/interface system 1016 takes the appropriate 
actions Of invoking context sensitive help routines 1050 or 
connecting the caller to an operator 1052. Preferably, after 
the caller has finished interacting with the operator (e.g., 
to receive assistance or to perform a process not readily done 
in an automated fashion) the user can return to the automated 
system. Preferably, the user can return to the system at the 
same point in the procedure that the user was at when the user 
requested transfer to the operator, i.e., it is not necessary 
for the user to begin automated processing again from the 
beginning of the procedure, as if the user were placing a new 
call to the system. This goal can be implemented by saving 
the state of the process, e.g., to a memory stack. 

In the absence of such inputs, the I/O 
connect/interface system 1016 prompts the user to make a 
Choice among the available options (such as those described 
»ore thoroughly below) 1054, receives the user choice and 
branches to the appropriate subroutine 1056, such as those 
described below. Upon returning from the branch or subroutine 
1058, the I/O connect/ interface system 1016 loops 1060 to 
check for help or operator requests and to prompt for the next 

user choice. . j 

A particular implementation of the system depicted 

in Pig. 3 involves a system for publishing a catalogue which 
is tailored to the likely interests of buyers, based on the 
buyer's agent or agents. The agent or agents preferably 
include three main components: data regarding buyer 
preferences and/or characteristics (stored in the buyer 
database, as described above) , hardware and activatable 
software for matching the buyers -s interests or 
characteristics to potential catalogue entries in order to 
compile a catalogue which will be of interest to the buyer 
(e.g., as described below), and facilities for transmitting 
the catalogue to the buyer (e.g., as depicted in Fig. 1). 

AS indicated in Fig. 4, the operation of the system 
is triggered by receipt of an incoming call, e.g., to the PBX 
via telephone line 20. In step 100, the PBX first determines 
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Whether the incoming call is voice, fax or some other medium. 
If fax, then step 102 connects the incoming call to fax server 
18 via'telephone line 50. The fax server receives the fax, 
and the fax may then be printed by a printer coupled to FAX 

5 server 18 or to DBS 16. 

If the incoming call is voice, the step 104 is 
executed. In this step, the PBX sends a message to DBS 16 via 
serial line 26, indicating that a new call has been received. 
In return, the DBS sends back a transaction identifier 
10 (TransId) that will be used to uniquely identify this call. 
In step 106, the PBX then connects the call to the IVR via 
telephone line 22, and transmits the transaction identifier to 
the IVR via telephone line 22, using touch tone signals. 

The steps in blocks 100-106 in Fig. 4 are performed 
15 by PBX 12, while the remaining steps in this figure are 
performed by IVR 14. In response to receipt of the 
transaction identifier for the PBX, the IVR in step 110 plays 
a pre-stored new caller voice script, and transmits this 
script to the caller via PBX 12 and telephone line 20. This 
20 script may include any introductory information, recently 

added features of the system, instructions on how to use the 
system, etc. The script then asks the caller to identify a 
desired function, for example by pressing designated touch 
tone keys on the caller's telephone. Block 112 then analyzes 
25 the function that the caller has requested, and routes control 
accordingly. 

The principal functions that the caller may request 
depend upon whether the caller is a seller or buyer. If the 
caller is a seller, then the caller can ask to place a new 

30 product in the database used to compile the catalogue. If the 
caller is a buyer, then the caller can ask the system to 
search for products that match its needs, and to generate a 
catalogue. In a particular implementation, numerous other 
functions could be selected at this point. For a seller, such 

35 additional functions could include changing an existing 
product description cancelling a product, playing back a 
product description previously placed, and modifying 
information concerning the seller itself, such as its phone 
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number or address, etc. For a buyer, such additional 
functions could include modifying, cancelling or renewing a 
previously created agent. 

If the incoming caller identifies itself as a seller 
5 wishing to place a product description or advertisement, then 
the IVR identifies this as a non-IVR based function, and sends 
an operator request message to DBS 16 via serial line 24, as 
shown in block 116 of Fig. 4. In response to the operator 
request message, the DBS begins prompting the operator at 
10 terminal 40 for information relating to the new product. In 
turn, the operator relays these requests to the seller via 
headset 42 and switch 12, receives the seller's responses via 
the same path, and inputs such responses to DBS 16, to create 
a new product description in ad database 30. Although this 
15 step could be automated using the IVR, a human operator can 
readily accommodate the amount of variability involved in 
placing an new product description, explaining to the seller 
the options available, etc. 

Fig. 5 provides further details concerning the steps 
20 used to create a new ad in ad database 30. In step 150, the 
operator asKs the seller to identify itself, such as by 
supplying a seller ID or other identifying information. If 
the catalogue is configured to serve only a single seller, 
steps 150-154 can be skipped. The operator then checks seller 
25 database 34, to determine whether the seller is already 

registered in the system. If the caller is a new seller, then 
the operator obtains information form the seller in block 154, 
and the new seller is added to the seller database. In both 
the automated and operator-mediated embodiments, the user can, 
30 in some cases, be given an opportunity to record a custom 
voice message. The custom voice message can be used for 
playback to prospective purchasers or recipients in various 
ways. For example, the seller may record a description of a 
product, which can be recorded by a voice mail-type system for 
35 playback when a prospective buyer requests information on a 
product. Alternatively, the seller could record information 
about related products for playback when a prospective 
purchaser has purchased (or requested the information about) a 
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primary product or for playback to a gift recipient, e.g. 
part of a "virtual greeting card" system described below. 
in one embodiment, the system can create an advertisement on 
behalf of the seller, using the information provided by the 
seller (such as price, condition, features, etc.). In another 
embodiment, the system can integrate system-created 
advertisements with advertising material recorded or down 
loaded by the seller (such as a voice mail-recorded message, a 
down loaded video advertisement and the like) . 

in block 156, the operator asks the seller if it 
wished to place a new product description in the system. 
Assuming that the answer is yes, the operator obtains the 
information relating to the new product in step 160. The 
information requested from the seller corresponds to the 
fields of the ad database. The fields in the ad database will 
depend on the type of products being listed in catalogues. 
For example, if the catalogues are being produced for a single 
software retail outlet, the fields might include such items as 
type of application (business, game, home management, legal) , 
type of program (database, spreadsheet, word processor) , 
price, features, availability, discounts, sales, coupons that 
can be used or provided, etc. 

DBS 16 then assigns an ad identifier (Adid) , and the 
new product with its AdId is stored in ad database 30. DBS 16 
then searches want ad database 32, in step 164, to determine 
if any of the previously stored agents have needs, interests 
or Characteristics which match the new product just received 
from the seller. This step could of course be performed 
either before or after the new product is actually placed m 
the ad database. Alternatively, the addition of a new product 
can cause the calling of a subroutine which scans all agents 
to determine which, if any, are to be activated by a product 
addition and which activates such agents (e.g. by calling a 
subroutine) , as described below. 

one technique for performing this matching step is 
outlined in Fig. 6. In this approach, the matching fields in 
the ad and agent databases are broken down into basic fields 
(e.g., type of program and price), and option fields (all 
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and fax server 18. In this case, the fax is printed or 
displayed to the operator of terminal 40, and the operator 
then inputs the information shown on the fax to create a new 
product description in ad database 30. In this case, the 
steps Shown in Fig. 6 are again carried out, to determine xf 
the newly placed product matches any agent interests or 
characteristics. The catalogue may be prepared and mailed (or 
otherwise transmitted) automatically, or the buyer can be 
consulted regarding transmission of the catalogue. 

Fig 7 illustrates an optional callback routine that 
determines if the buyer wants a catalogue. In step 200, the 
DBS scans the callback queue, to determine if any callbacks 
are scheduled to be made at the present time. Each callback 
record includes the buyer's phone number and time information 
concerning when callbacks should be directed to that phone 
number. Block 202 determines if the time information in any 
callback records matches the current date and time. 

For callback records in which the information 
matches, step 204 pulls such records from the callback queue, 
and sends them (e.g. in text form) to the IVR. In step 206, 
the IVR dials the buyer's phone number contained in the 
callback record, and waits for a response. If a voice 
response is not received, then the IVR sends a corresponding 
message to the DBS. The DBS then marks the time of the 
attempted callback in the callback queue record, so that a set 
period of time can be established between callback attempts in 
step 202. The callback routine resumes scanning in step 200. 
If a voice response is received, then in step 210, the IVR 
sends a voice message to the buyer via the PBX, asking the 
buyer to make a predetermined touch tone response if the buyer 
would like the catalogue transmitted at the present time. If 
the buyer's response is positive, the catalogue is prepared 
and sent 216. If the buyer requests telephone transmission of 
the catalogue, then the IVR assembles a voice message by 
identifying the individual words and phrases contained in the 
product description, retrieving the digital voice records 
corresponding to such words and phrases, and concatenating the 
individual voice records into a single message. This message 
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is then relayed to the buyer in voice form via telephone 
switch 12 and telephone line 20. When product description 
playback is complete, the IVR sends a corresponding message to 
the DBS, and the DBS removes the callback record from the 
5 queue in step 218, and then resumes scanning. 

If the buyer does not wish to received a catalogue 
at the present time, the buyer may provide a negative 
response. The buyer may call in at a later time to request a 
catalogue, as described below. An option could also be 

10 provided to enable a buyer to request receipt of the catalogue 
via fax, modem, m?iil, cable, etc. 

Fig. 8 illustrates the steps performed when a buyer 
calls the system to request a search. In general, a buyer's 
catalogue request can be handled by an operator at terminal 

15 40, or by IVR 14. The following discussion will assume that 
thl buyer's catalogue request is routed through the operator 
of terminal 40. However, analogous functions could be handled 
by the IVR, for systems in which a lower degree of flexibility 
is suitable. 

20 Referring again briefly to Fig. 4, for the case of a 

buyer's catalogue request to be handled by an operator, IVR 14 
will send an operator request message to DBS 16, as shown in 
step 116. Referring now to Fig. 8, the operator at terminal 
40 will then obtain information from the buyer, in step 250, 

25 in order to create a "profile" for the catalogue request. In 
general, a "profile" corresponds to an agent record, except 
that the profile has not yet been stored in the agent 
database. Thus, the information requested by the operator 
will correspond to the fields of the agent database. The 

30 operator also obtains an output method from the buyer, e.g., 
voice or fax. 

For the case in which the buyer's catalogue request 
is being handled by the IVR, the IVR would at this point send 
the profile and the output method to DBS 16. However, for the 
35 case being considered in which the buyer's search request is 
handled by the operator, the DBS already has this data. In 
either case, the DBS proceeds in step 252 to search ad 
database 30 for products matching the profile. Block 254 then 
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determines whether any matches have been found. If not, 
suitable message is sent to the buyer in step 256, via either 
the operator or the IVR. Control then returns to block 250 to 
permit the buyer to specify a different profile or quit. 
5 If step 254 determines that matches have been found, 

then step 260 determines the output method that the buyer has 
specified. If fax output has been specified, then step 262 
sends the matching ads to fax server 18 for output via PBX 12. 
control then returns to step 250. If voice output has been 
10 specified, then step 264 sends the matching ads to IVR 14. In 
step 266, the IVR proceeds to play the matching ads back to 
the buyer. This process is also further described below. In 
step 270, the buyer is then asked whether it wishes to convert 
the currently searched profile into an agent. If the buyer's 
15 response is affirmative, then the IVR sends a corresponding 
message to DBS 16, and the DBS proceeds to store the profile 
as a new agent in the agent database 32. In both cases, 
control then returns to step 250. 

Fig. 9 illustrates a preferred, interactive 
20 technique for carrying out the playback of matching ads by the 
IVR, in step 266 of Fig. 8. As in the case of playback of the 
callback queue described above, the IVR performs the playback 
by assembling a voice message in real time. The voice message 
is assembled by identifying the individual words and phrases 
25 contained in the ad, retrieving the digital voice records 

corresponding to such words and phrases, and concatenating the 
individual voice records into an output message. For the 
purpose of this playback, the fields in each ad are preferably 
separated into "summary" fields and "detail" fields. In 
general, the summary fields of the ads are assembled and 
played back sequentially, beginning with the first product in-- 
step 300, and ending with the last product in step 310. 
However, during the playback, the buyer can control the 
sequence, e.g., using predetermined touch tone keys. For 
35 example, one touch tone key would correspond to the 

illustrated "More" function that causes the detail fields of 
the current ad to be assembled and played back. If the More 
function is not used, then detail fields are omitted. A 
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second touch tone key would correspond to the Repeat function, 
which causes either a repeat of the summary fields of the 
cxirrent product description if details are currently being 
played back, or causes the prior ad to played back in the case 
5 of summary playout. A third key would be dedicated to the 
Skip function which causes the playback to skip ahead to the 
next ad in the sequence. 

In the example above, matching is accomplished by 
the system comparing a new product to each agent in the 
10 system. The system can also be configured so that each agent 
is proactive in the process, in the sense that agents can, at 
specified times or under specified conditions, become 
activated 1070 to search the product database for matches to 
themselves. As depicted in Fig. 10, a number of events can be 
15 used to activate an agent. One such event is the addition of 
a new item (or addition of a specified type of new item) to 
the database 1072. Another event is the passage of a 
specified period of time, so that the agent is periodically 
activated 1074. Another event is the modification of the 
20 agent profile or portfolio 1076. Another event is the 

impending occurrence of a date associated with the user, such 
as a birthday of a family member or the like. In this 
instance, the system can provide an automatic (i.e., without 
human intervention) reminder service to a user or subscriber 
25 to remind the user of events such as birthdays, anniversaries, 
etc. In one embodiment, the reminder service can be combined 
with a gift suggestion service to suggest appropriate gifts 
for birthdays, anniversaries, etc. The appropriate 
suggestions, in one embodiment, can be based on the user's 
30 history of gift-giving via the system, supplying such 

information as the price of gifts given in the past, type of 
gifts given in the past and the like. Other events that can 
be used to trigger a reminder is purchases of certain types of 
items. For example, one year after a user purchases a new 
35 carpet, he can be reminded that carpet cleaning services are 

available. Specified times after purchasing a new car, a user 
can be notified that it is time for a tune-up and/or it is 
time to trade-up to a new model. In this regard, this system 
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can Bake beneficial use of purchase histories from sources 
other than purchases made through the system (such as from 
credit card companies, product registration services, and the 
like) . Reminders could also be provided with respect to 
5 periodic charitable or non-profit donations. Each agent can 
be configured to activate upon different events or conditions 
(or can be a purely passive agent, only storing information 
for query by other processes, such as in Figs. 4-9) . 
Although, in one embodiment, the user is offered the choice 
10 whether or not to create an agent, in another embodiment, 
agents can be automatically created without the need for a 
user request, e.g., such that an agent is created or updated 
every time a user communicates with the system in such a 
fashion that the user can be identified in some way. 
15 once the agent is activated it executes a subroutine 

designed to select items which are of most interest for 
inclusion in a catalogue. In this sense, the electronic agent 
performs a shopping function for the user. In the selection 
procedure depicted in Fig. 6, selection was by an elimination 
20 process, in which the product must meet certain criteria. 

Fig. 10 depicts an alternative selection process in which each 
product is assigned a score representing the closeness-of-f it 
to the agent's defined interest or characteristics. In this 
way, a predetermined number N of products which are the 
25 closest fit to the interest or characteristics of the agent 
can be selected. The definition and selection of items for 
inclusion in the catalogue can be determined interactively 
with the prospective purchaser. For example, the system can 
notify the purchaser of how many matches have been found and 
30 invite the user to, for example, narrow the search by adding 
another criteria in order to provide a smaller number of 
matches. In one embodiment, if the criteria added by the 
prospective purchaser results in zero matches or an 
unacceptably small number of matches, the user can be invited 
35 to -back up" one level by removing one or more criteria to 
provide a larger number of matches. 

Any of a number of criteria can be used for 
selection. The example illustrated in Fig. 10 calculates 
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three scores based on the agent's interests, demographic 
information and purchase history. The procedure loops through 
all products 1078, 1080, calculating a score for each. The 
system could be configured to store the scores for old 
, products and to calculate and store scores only for new or 
modified product description. In the depicted example, an 
interest score (IS) 1082 is calculated on the basis of a score 
representing the product type and a score representing the 
agent's interest. If the agent has more than one interest, 
the interest closest to the product type score can be used. 
Alternatively, a weighted average of the difference of all 
agent interests can be used. As one example, if the products 
are all software, the system could assign a score of 1000 to 
word processors, 500 to spreadsheets, 50 to databases and 900 
to forms generators. Forms generator scores are close to word 
processor scores, since there are similarities in the 
products, suppose the agent has an interest in word 
processing. If the product is a forms generator, IS = 100 (a 
relatively good or low score) . If the product is a database, 
IS = 850 (a high or bad score). Thus, this agent will 
generate a catalogue which includes word processors and forms 
generators, but will not likely include databases. 

The demographic score (DS) 1084 is calculated by 
comparing the buyer's demographic data with the demographic 
data which describes the most likely buyer of the product. 
Again the score is taken as the absolute value of the 

difference. . , 

The product history score (PS) 1086 is, similarly, 
the absolute value of the difference between the product type 
score and the score for the closest previous product purchased 
by the buyer. Thus, ah agent has stored information about 
previous purchases so that if the buyer has purchased a user 
interface (such as WINDOWS") , the score for related products 
(e.g. word for Windows™) will be relatively low (i.e. good). 

The sum of the three scores is calculated 1088 for 
each product and stored. After all products have been 
reviewed 1080, the products with the lowest scores can be 
selected for inclusion in the catalogue for this buyer. In 
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one embodiment, the system matches prospective purchasers with 
products being offered by any or all members of the public who 
wish to advertise on the system (such as in an "electronic 
classified ad"). In another embodiment, the system may be 

5 used exclusively by one manufacturer or retailer for selling, 
exclusively, its own goods. In yet a third embodiment, a 
configuration between the "electronic classified ads" and 
"exclusive" system can be used in which one or more 
advertisers may pay for the privilege of having its products 

10 more heavily-weighted or more frequently-considered in 

processing a matching procedure such as that depicted in Fig. 
10. 

The system described here includes software running 
on various integrations of hardware, which accomplishes 
several tasks, including the "self -publishing" or automated 
publication of catalogs, by software "agents". Agents are 
created when users interact with the system described here, 
and represent users in on-going transactions within and 
between databases outside the consumer direct interaction and 
beyond their initial interaction. Additionally, this system 
leverages the abilities of such a system to add/ interactive 
benefits to both the advertiser and consumers, including 
certain virtual products as described below toward the end of 
created highly automated self -publishing, customer servicing 

25 and new services. 

The system provides inventory and ordering 
functions. At least some features center on (1) the "agent" 
Vhich resides in the database representing each consumer and 
gathering information on consumer interests and 
characteristics, (2) the agent's function of shopping for the 
consumer, (3) the agent's function of automatically compiling 
and/or transmitting custom catalogues of specific interest to 
the consumer represented by the agent and (4) and the systems 
function of offering advertisers "virtual" invoices, 
35 greeting/gift cards and other interactive support of the sale 
form the catalogue. A virtual invoice consists of a telephone 
number and invoice number posted on the item ordered and given 
to the buyer. It can be used to track the item instantly, 
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seek customer support for the product through the system and 
provide other related information by voice (computer 
concatenated or text-to-speech) , fax back, electronic or other 
means. The virtual document facility can be used to send 
documentation for the product via fax or electronic means 
while simultaneously serving to register the user upon their 
calling, confirming delivery. 

For gift catalogs, or retail sales services 
conducted by telephone or electronic means the system can 
create a "virtual greeting card" which is be shipped with the 
item sold to the recipient in the form of a phone number and a 
second "greeting number". The recipient would call the 
telephone number on the "virtual gift card" and hear a voice 
message recorded by the customer sending the gift (stored xn a 
voice mail box in the system) . The recipient can also choose 
to hear more information about the catalogue, order a 
catalogue or go "on-line" to respond to the sender. Rather 
than sending paper registration or documentation with an item 
or product shipped, a "virtual manual" or "virtual 
registration card" could be sent. Again, a telephone number 
sent with the item and delivered in real time to the buyer as 
they ordered, allows the customer to request information by 
whatever means they wanted in terms of documentation 
registration and service. This would limit paperwork on many 
orders and provide the customer special premiums for easy 
quick registration or other desired action. 

This product would rvm on equipment similar or 
identical to that disclosed in U.S. Serial No. 07/819,484 and 
the continuation-in-part thereof U.S. Serial No. 07/945,748, 
filed on December 23, 1992. That disclosure features a 
computer "agent" created inside a database of classified - 
advertising, which "remembers" (i.e., stores in memory) every 
caller's request. A caller calls into the system and builds a 
query (answering by touch tone or other means including an 
35 operator or a personal computer or other device) . VJhatever 
data (ads) are available, they are delivered to the caller 
instantly, by phone (concatenated voice), fax (including any 
photos attached to the ad), or other communication devices. 
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The agent will then reside in the system, acting as the buyer 
or seller's "representative" examining every piece of incoming 
information. Alternatively, the agent may be activated 
periodically or upon the occurrence of predetermined events to 
5 perform a shopping function by comparing the interests or 
profile of the user to the product or advertising database. 
V?hen new data (in this case ads) are entered onto the system, 
the agent stores the new ad's identification number, and then 
notifies the consumer by whatever means and at whatever time 
10 the consumer has chosen, or leaves a message when it detects a 
voice mail system (e.g., due to failure to detect a touch tone 
response) . Alternatively, the agent may convey information to 
the consumer without relying on stored consumer communications 
preferences, such as by sending periodic advertising 
15 customized to the user's interests. Preferably, the system 

assigns a nimber to each incoming ad (which could apply to any 
media including broadcast or personal communication devices) . 

As noted above, advertising can be associated with 
an advertising number such as by printing or displaying an ad 
20 number in connection with a telephone directory advertisement 
or listing, in connection with a catalogue entry and the like. 
When the caller calls regarding one specific ad number, the 
system automatically searches the entire inventory of the 
system or of the specific advertiser for similar items 
25 matching parameters in the database for the advertised 

product. One call thus lets the consiimer quickly find out 
about all similar properties in the database, e.g., based on 
criteria the consumer creates (and based on the fields chosen 
by the system as "comparable" items) . This makes the print, 
30 broadcast or personal coxamunications device interactive. 

Finally, the system creates a number for each 
"agent" and tells the consumer that the number can be used to 
call back into the system to instantly check on any new items 
on the system. This is for use by, e.g., consumers who do not 
35 want the system to contact them automatically. 

One embodiment of the present invention includes a 
self -publishing, interactive catalogue, utilizing print, fax, 
personal computers or person communications devices. It, too, 
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creates an "agent" for each shopper. In one embodiment, the 
company provides a catalogue number for each product and, 
optionally, and provides certain premium interactive services 
which can be utilized by the catalogue customer, as described 
5 above. The system can create catalogues to be published 
electronically (by PC or fax or other means, including 
telephonic means text to speech or concatenated speech 
system) . There can also be mass mailed catalogues, but the 
idea behind the system is to reduce their number and target 
10 their mailing. Also, the system can let those with no 

catalogue find what they are looking for 24 hours a day using 
a PC on-line and/or interactive voice system programmed with a 
sophisticated relational database. Product registration can 
also occur 24 hours a day as can invoice information using a 
15 unique product/ customer number created for each transaction, 
combining the various technologies used by this system. 
Direct connect options for operator help can be made available 
to take information such as credit card numbers, addresses, 
etc., to set up ID (accounts) to simplify the ordering and 
20 information gathering process described below. 

The agent represents each consumer, and includes one 
or more activatable computer routines which continuously 
and/or periodically represent the consumer in the database 
and, based on new activity in the system, automatically 
25 publishes catalogues tailored to the characteristics or likely 
needs of the consumer. In one embodiment, an interactive 
print number is provided, by which a consumer who chooses to 
call about one item in the catalogue is informed about all 
similar products (by vender, or function, or other parameter 

30 e.g., set by the publisher). 

The caller enters the system e.g., via telephone, 

computer or other communication-device with or without an 
"agent", ID or catalogue n\imber. An agent number can be 
provided by the caller's direct interaction with the system, 
35 as described below, or by other means such as filling out 
cards at retail outlets, by direct mail, or electronic or 
telephonic means. With an ID or agent number, the system 
recognizes the caller. The caller can order by catalogue 
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r^r including orderin, catalogues, request an update .aeed 
on previous rec,uests (the agent's worX on behal of the 
Luer, or add or delete areas/ltens of interest or direct 
^nJt to an operator for special help. All actxvxty xs 
, rrerved- .y the agent which continuously shapes the agent 

If the caller has an existing account and wishes to 
erder a new product, they ^ rrenrj 
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order a new proauwu, ^^^j - - 

tro. a catalogue or other source. The system wxU ^en 
Lre of getting the product shipped. It retrieves the 
Wiling shipping and other infon^tion fro. the account file, 
r:::' infection ahout the order will he added to the 

bulletins and custom catalogues for each agent, with new 
tnfo^tion Of interest to the caller/custo»er, based on the 
^!t"la m their agent file. Windows' users, for example, 
Till hear ahout «lndows- products. Macintosh- users about 
Mcintosh- products. «ln«ord" users will "-■^^-^ f ^ 
related WinWord products. The agent will, for examp e. 
i„edlately notify consumers of updates, new releases, or 
closely related products, by fax. mall or even phone wot 
lilv cL these custom catalogues be sent by fax, mail and/or 

t^:; can be used as covers for mass mailed catalogues. 
^iZ l^ mass mailed version custom to each user and more 
mely to draw attention. There c«, also be an "urgent 
i^tScation- function by which the system vlU automatxcally 
! ii!hL fax or page a caller when the product they need 
:"rs T^fs can'b! particularly useful to small businesses 

«bo need „lthOut an 10, 

to build an agent based on the guery they maXe, using e^er 
an interactive voice response system or other means. Operator 
ass Ince can be made available to speed this process u^ 

1 n=: r rinra^r o^ ^ 

irerorbrgiven an agent ^ 
call back at any time to request instant, seit p 
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catalogues of interest, or to order 24 hours a day. The 
system can feature a direct connect option to a human operator 
or vender in the case of help service. 

The system would shorten order time and automate 
order fulfillment by sending and order in real time to the 
point of shipping, while also updating company inventory files 
and producing demand reports. "Just in time" inventory 
control can be used, routing the order directly to 

manufacturers. 

The statistical benefits of assigning the agent to 
each caller, and having it create a virtual catalogue for each 
user are many. The company using this system can track 
demand, target customers, save money and time. It can also 
allow the company to tailor education programs to certain 
clusters of users, in the form of custom newsletter or other 
information a manufacturer might want sent to certain 

customers. .^^ w w 

The company can determine the f reguency with which 

it publishes bulletins or catalogues. One command can 
20 activate all "agents.- to update their catalogue bins with new 
information and publish a catalogue for each user. The agent 
ID can also be used to target and reward small business and 
frequent users with special promotions, discounts and other 
benefits. The system can be programmed to greet each user 
25 personally when their ID is entered. This can be done by 
allowing the user to speak their name, or through 
concatenation techniques or on line via PC. 

Fig. 16 provides an illustration of a manner in 
which advertisements, listings or entries in, for example, a 
30 telephone directory or catalogue, can be used to provide 

automatic shopping functions for a user. In the embodiment of 
Fig. 16, the telephone directory or catalogue is published 
along with code numbers or "ad numbers" which can be used to 
fully or partially identify the advertisement listing or entry 
35 1602, 1604. In this embodiment, the user reads or views the 
advertising listing or entries in the catalogue or directory 
and communicates with the computer system such as by placing a 
voice telephone call, sending a message by fax, modem, cable 
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or the like. In ccMnunicatln, with the system, the user 
refers to the ad number 1606. In response to reoexving the 

»v,. „«o.- the system creates or updates an 
communication from the user, the sysie 

aaent using the ad number. In particular, the ad number 
S 'e^itrth! system to fully or partially determine the nature 
and location of the advertisement listing or entry xn the 
directory or catalogue. This information can be used to help 
determine what the user is purchasing or ingulring '^-^J^ 
well as to obtain information about the user (such as that the 
10 user consults a particular telephone directory « " 
The system preferably performs the service re.r>ested by the 
user in his communication (such as ordering a product or 
providing requested Information) . Further, the agent 
prlferabl also obtains Information about related products or 
15 se^rces, such as products or services which the user ordered 
or"n,ui;ed about or products or services which are related, 
such as supplemental products, add-on products upgrade 
products and the like. This Information can then be 
transmitted to the user 1608. Further, even after the 
20 transaction requested by the user In his original 

co^unication (such as ordering a product or transmitting ■ 
initial information, Is completed, the agent continues to 
Lnltor the database to identify products or servic^, sales 
or other promotions, coupons and the like based on the 
„ information available about the user (such as the user's 

i^Lests, requirements, characteristics,. In this sense the 

orms a Shopping function for the user by gathering 
iLormltlon likely to be of Interest to the user. «'^"'-^ 
;;ser having to bear the burden of gathering this information 
30 1610. This function of shopping or monitoring, as an 

alternative to being conducted In a continuous manner, can 
also be conducted periodically or upon the occurrence of 

predefined events. 

in one embodiment, a procedure is provided for 

35 determining the degree of difference between the ^^2TT.ll 
the user originally ordered or Inquired about, and some or all 
of the products or services having Information stored in the 
aatabaseao. This can be done In a number of manners. The 
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measurement can be computed for each entry In the database or 
for only certain categories in the database. A rough 
Tasurlent o, difference can be co^uted and a »ore accuse 
difference can then be computed only for those iteBS vh^ are 
sufficiently Close, based on the initial rough measurem«.t. 
L measurement can be conducted periodically. 
conducted vhenever a new product or service is added to the 
:::^:^:ror an ^d product or service -criP""-^^ 

i-hP user becomes available. Tne 
or new information about tne user 
, l™t Of difference can be stored or can be computed on 
the fly" Whenever it is desired to prepare a pacXage of 
information for transmission to the user. ,a.„tifv 
The difference measurement is then used to identify 
, subset of the items in the database which are sufficiently 
3 iZt L apparent interests or characteristics^f ^e user 
that they should be included in a transmission to the user, 
in one embodiment, all products or services within a 
prrefined amount of difference are members of the subset. In 
Lother embodiment, a predetermined number of product and 
>„ se^ioe descriptions (e.g.. » descriptions, will be sent and 
closest products or services will form the subset In 
ZLr embodiment, the subset may also include items which 
are not particularly close according to the measurement of 
differenL. For e:cample, the Information transmitted to the 
„ TZ L include one or more items which are net close to the 
Te-eived user Interest or characteristics but have been 
randomly selected or have been selected on ^J^^^^ 
promotion or advertising considerations so that the "^-^ 
receive Information having a number of products l^^'^V " 
30 Of interest, interspersed with products which may « may not 
t Of interest. However, in order that the information will 
be customized or targeted to the lllcely user interests the 
subset will not contain every product and service in the 
rctnlc database and there will be at least one product or 

3S service which is not included 'j^^^^^^^'XlT:^ ^^^^ „ 
measurement of difference greater than at least on 
service which Is in the subset. 
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The concept o£ an agent has numerous other uees in 
an interactive ccputln, =yste», in addition to assisting in 
^^ovision Of a self-publishin, cataXogue. Including coupon 

• A^r^ini-f>A in Fig. 12, automatxc 
delivery and processing, depictea in rxy » 

, „:im»tion o, advertiser, in-hound poiling, depicted .n Fx,. 
15 all described in greater detail in U.S. Serial No. 
osmose, 701, incorporated herein by reference. 

^ 18 aeplcts the previous approach to on-hold 

„ana,e.ent. According to previous approaches when a systeB 
receives a call which Is appropriate for transfer to a 
particular resource (for example, an operator, which is 
Lrently busy, the caller Is typically placed on hold In 
rrtte^. the caller is offered a choice ISO. t^ either 
.ait for the operator who is busy or to proceed with an 
autcated procedure. *s shown in rig. 18. according to this 
Ltem If the caller choose to wait for the operator, the 
^all l; placed at the bottom of an electronic list or gueue of 
callers waiting to be connected to the operator ia04. A 
caller in the ^eue will normally be connected to the operator 
or ot^er resource before other callers who entered the queue 
llt!^ The caller holds while the call worKs Its way to the 
top of the queue, I.e., as the operator processes in turn 
„ each call In the queue isoe. Eventually, the ca 1 wh ^ s 
holding reaches the top of the queue 1808 at which point 
connected to the operator 1810. 

If on the other band, it the caller had requested 
an auto-ated procedure, the caller will typically be invited 
30 to selected fro. among a variety o£_ options 1812 , such as to 
hear a recording about store hours 1814, to order one or more 
i«L 1818, or to Obtain price Information 1818. The user is 
lirofferU the option to decide to wait for the "P^'tor 
1820 in the depicted embodiment, after finishing one of the 
3= automated procedures 1814. 1818. 1818. The caller may select 
1812 another option. As shown In Fig. 18. ">7=- "^^^^ 
Lerlng an automated procedure loop, selects to wait for the 
Tp^rator 1820. the user then enters the bottom of the queue 
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xao4 Thus, according to the previous procedures of Fig. 18, 
" a user sUects an autoxated procedure, the user cannot at 
the sase ti»e Balntaln his or her place in the 
Lt, after leaving the automated procedure, enter the hotter 

5 of the queue 1804. 

Fig 19 depicts an embodiment according to the 

present inven;ion in which the user can select - ----- 

Uedure without losing his or l^^Z. 
^ • 4.^^ ^« T?irr 19. after receiving a can, " j 

he routed to a resource ,s^oh " " J---* ^otto. o. 

currently busy, the user call will be place 
the queue for the operator 1902. As before, the call works 
Z Tay to the top of gueue. However, the call can he held in 
the queue simultaneously with automatic processing. Thus, at 
ZZ time that the call is waiting in the queue «04, the 
Tlleris also given an option l,Oe to select -"^ ja-ous 
automated procedures such as hearing about store hours 1908 
t^eri^^ items 1910, listening to music 1912, or hearing price 
ilfo^aticn 1914. According to one embodiment, if the user 
s^Hots to listen to music 1912, the user is then prompted to 
seie^ the type of music (for example, classical, popular, 
,ollcl or silence. During the time the selection and 
Tc s in^ is going on 190S-1914. the call is — ^ ^ 
Lwnq its way to the top of the queue 1904. «hen the call 
reaches the top of the queue, an interrupt procedure is ^ 
undertaken 1916. In the embodiment shown in Fig. 19, the 
^terrupt procedure operates by setting a flag to indicate 
interrupt f irter the selected option 

that interrupt is now appropriate. After the se 
is finished 1908, 1910, 1912, 1914, the system checks to see 
Aether the interrupt flag has been set. If ^ -"^^^^^ 
flag has been set. the call is routed to the operator 1920 
I L interrupt flag has not been set, the user is given the 
opportunity to continue automated processing 1906 since this 
meL the call is still working its way to the top of the 

■^^"^^ in the embodiment of Fig. 19, once the interrupt 
procedure is initiated, the currently-underway processing 
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■.on A is allowed to finish before checking 
,303, 1910, ,,,.,,.ent, one or »ore of the 

the interrupt flag- ^ ^^^^^ ,,,, ,e immediately 

automated processes 1908, , ^^^^ 

interrupted when the call Sample, if 

3 Without waiting for the proces t f xn^sh- ^^^^ ^^^^^ 

^^^^ rii: rto Ilsi t-., recording or music can 

1908, or to listen to m transferred to 

- i-e.U.eXy ^-^^ ,r r-=°::e top the ^eue. 

interruption, since ,e preferable to 

on-,oin, order process. In that ^ J 

wait until the current proced^^ '^^'iZ,^ ^.ore 
appropriate -stopping poxnt ^aa been 

interruptin,. Xn c.Xi whose 

transfer the next call in table) for 

—\ rr::it:rThrrs;:e. ^ ...... ^^^^^ 

. rauTt:: z ... to reach > stoppm, pomt. 

^-^^^^'^^'^^t^. Which .a, be Offered b, the e^ste. 
i3 an estl^ted ti»e of arrival ,ET., ^PP---"- 
,s exa^le of this application is dep.c ^^^^ 

" the -"--^r/et ;ro.pted to select one 

,iven a ,„,erin, a choice on a telephone 

of three choices, such as y ^,^ie of Fig. 20, 

Keypad or other input ^^^^'^ Jl^Zter to the operator 
30 selection-6f Key o ^TT^'^^^ to In^ire about 
2006. Key 1 2008 indicates the 

. v^,.r^^^llc+l Will bBCOiae avaiiaoie ^^J•^^ 
the date a P'^f ^'^^ "'^^^^ to inquire when the 

Key 2 2012 indicates the user wx ^ 

product that the user ^ ^ut new product 

- riri":; t^: user is -----rirt^^r ■ 

euch as by entering the product number 2016. 
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wishes « inquire about shipping dates, the user is prompted 

to enter a P-^*"" ""^^^/"/^^ ,,,, p„,,i,le. As noted 
Other configurations are aiso pu=.=.x 

ahove, m one configuration, the routing computer plays a roXe 

deUr-ining which resources are best salted to th.s call 
and may, for example, determine whether or not the 
Z tra^ferred to the operator 2..06. In such ' 
this function is performed hy the routing ^-P"*-' " " 
necessary for the application to perform thxs function, 
necessary ^^^^^ the application has access to 

a database of ordered products. In such a case, the 
tpplication may asK for the product ^ 
Zr and then determine whether this is a product v^-^" h»^ 
Zn recently ordered by the user. If "-^ P-?»- 
ordered, the application can provide the shxppxng date, 
without the need for the user to, for example, enter a 
;^hase number. If no product has been recently ordered by 
L user, the application can provide information about 0,e 
^Lct, including, e.g., availability date or may prompt the 
user to indicate more specifically what information is 

desired. ^^^^ i„„^,tion reguested or needed by the 

user is identified, it is necessary for the system to 

. ^ «^«>^ai-ion In one embodiment, 

determine how to deliver the information. In on 

the system has access to a database containing information 
!^ut the user. In one embodiment, the database will include 
"i^irrmation about how this particular user prefers to have his 
information delivered, (e.g., via telephone, via fax, via 
mail, etc.) and will output the information accordingly, 

my after verifying the preferred delivery -^-"^ . 
Le user. In the embodiment of Fig. 20. the system prompts 
the user to select an option for delivery of the information 
2022. in the embodiment of Fig. 20, entry of "-e 1 key 
indicates a preference for aural delivery 2026 which is then 
provided by the system, e.g., over the telephone via an 
proviaeu jr The user is then given the 

interactive voice response system. The user is 
option to also receive the same information via fax by 
entering a 1 Key 2028 or to terminate the session by entering 
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a 2 key 2030. If fax delivery is requested, the user is 
prompted to enter the fax number 2030 or the system retrieves 
the user's fax number (from the user database) and the user 
then receives the fax 2032. If, on the other hand, the user 
5 chooses to receive the information primarily via fax by 
entering the 2 key 2034, the system either retrieves the 
user's fax number from a database or prompts the user to enter 
a fax number 2036 which is then received 2038. The user is 
also given the option to additionally receive the information 
10 via an aural transmission by pressing a 1 key whereupon the 

information is transmitted, e.g., by an IVR system 2042 or to 
terminate the session by pressing the 2 key 2044. After 
termination of the session, a thank you message is deliver 
2046 and the process is completed. 

Another application provides information about the 
location of various resources, such as the location of the 
nearest retail store which is currently open, the location^of 
20 a narticular company representative, such as a salesman and 
th'e like 1728f , 1728g. Fig. 21 provides one example of such 
an application. In the embodiment of Fig. 21, after providing 
a welcome message 2102, the application prompts the user to 
enter a 0 key 2104 in order to transfer to the operator 2106 
25 or to enter a 1 key 2108 in order to begin the locator 

service. The embodiment of Fig. 21 is directed to a system 
for providing information regarding the location of stores. 
The user is prompted to enter information regarding the user s 
location such as entering a zip code 2110. Other items which 
30 could be used to indicate the user's location include 

telephone number or area code, address, and the like. ^In 
another embodiment, the application has access to a database 
containing information about various users, and if the current 
caller is included in this database, information about the 
35 caller's location may be obtainable from such database. F. 
example, the database may include information about the 
location of the caller's residence, information about the 
. location of the caller's place of business, or information 
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trou Which location information can be derived, such as zip 
code, telephone number and the like. 

After obtaining information regarding the caller s 
location, such location- is compared to a database containing 
information about the location of various stores. In the 
embodiment of Fig. 21, the application determines whether 
there are any stores located within a predetermined distance 
(e.g., 25 miles) of the caller's location. If there are no 
stores within the predetermined distance, the caller as given 
several options. The caller may enter the 0 key in order to 
transfer to the operator 2016, may choose to terminate the 
session by entering the 2 key 2018, or may choose to search 
for a store located with respect to another location by 
entering a 1 key 20 2120. For example, if the system 
5 indicates that there are no stores within 25 miles of the 

laller.s residence, the caller may enter key 1 2120, returning 
the caller to block 2110 and the caller may enter, for 
example, the zip code of the caller's place of business. The 
system outputs the requested location information, preferably 
20 via a medium requested by the user (such as voice or fax) . In 
one embodiment, the fax information can include a map showing 
the requested location. The audio or telephone information 
may include, in addition to the street address, store phone 
number, store hours, etc., location information including, 
25 e.g., landmarks or cross-street information. 

Tin i fled Systems , , 

"71^ 22A-22D depict a unified system containing 
several features described above, according to one embodiment 

30 of the invention. In the depicted embodiment, the caller 

initially receives a welcome message and/or menu selections 
2202. unless the caller chooses to be transferred to the 
operator 2204, the caller enters information locating the 
caller e.g., by zip code and soliciting information about the 

35 caller, e.g., the type of equipment which the caller has 2208, 
in one embodiment, the system for use by a software 
distributor and the system may ask whether the user has a 
Macintosh or a PC-type system. 
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The user is then given options to select one of 
several types of browsing procedures 2210. Selection 1 
permits the user to select 2212 among various types of 
catalogues, for example, an office product catalogue 2214a, a 

5 home product catalogue 2214b, a utilities catalogue 2214c, an 
entertainment/education catalogue 2214d, and a hardware 
catalogue 2214e. Preferably, browsing for items will be based 
on the caller's type of hardware (e.g., PC or Mcintosh) , 
categories of software that support the caller's hardware and 

10 top selling products within those software categories. Among 
the items played back or sent to the user as the catalogue 
entries, the user can, use key entries 2216 to perform 
functions such as repeating product descriptions, skipping to 
the next product description, browsing through multiple 

15 category descriptions per call, requesting to see hard copies 
.Of product information or to hear further particular product 
information. 

Other "browse" types which the user can select, 
assuming the user does not choose to transfer to an operator 

20 2218, is browsing popular items such as browsing the 10 top 
selling items 2220. In this case, the user can select to 
receive information via fax 2222 or can receive information, 
e.g., over the telephone lines 2224. In the various browse 
modes, the user can receive information about availability and 

25 pricing, including discount pricing 2225, can choose to 
transfer to an operator 2226, can choose to receive 
information via fax 2228 and/or in audio form 2230 and can 
order products including providing ordering information such 

as shipping address 2232. 
30 Another option selectable from the mam menu 2202 is 

requesting information regarding a store location, hours, etc. 
This procedure is depicted in Fig. 22C and similar to that 
described above in connection with Fig. 21. 

Another option available from the main menu 2202 is 
35 an interactive catalogue depicted in Figs. 22A and 22D. In 
general, this procedure permits a caller to find and order 
items by entering, for example, a product number. In the 
procedure depicted in Fig. 22A, the system first requests a 
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user to enter a user identification number such as a P«ferred 
customer nuxaber 2242. The user then is prompted to enter the 
product number 2244. The product number may be available to 
the user from, for example, another form of advertising, such 
5 as print advertising, or from the interactive system such as 
the browse system described above. In response to entry of 
the product number, the system can provide information such as 
product availability, availability date, price and the like 
2246. The system also provides the ability to place orders 
0 including options for requesting faxed product description 
2246, audio description 2250. When the user wishes to place 
an order, the system prompts for entry of quantity being 
ordered and shipping options 2252. If the caller selects zero 
items to order, the caller is presented with various browse 
L5 options similar to those described above 2255. Preferably. 

the system reads bacK information so that the user can verify 
the costs associated with the order 2254, tax, shipping and 
grand total 2256. The user is given the opportunity to change 
the order options or to enter a credit card number for billing 
20 purposes 2258. The user is supplied with a transaction number 
for the order 2260 and then given options to return to the 
„ain menu 2262 to enter a new catalogue number 2264 to record 
comments 2266 whereupon the session ends 2268. 

in various embodiments, the interactive catalogue 
25 cah contain a number of features. Among these features is the 
ability of the caller to, in response to a product number, 
hear the product name, availability and price, regular price 
and discount (e.g., preferred customer) price, or for zone 
pricing, a price determined from the caller's zip code or 
30 other location information. Preferably, the system can 

determine the quantity of each ■ item to be- ordered . The user^^. 
can request multiple items per order and place multiple orders 
per call. Preferably, the system will obtain the user's phone 
number or other communication identifier for contact in the 
35 event of a problem with an order. At the end of an order the 
caller can hear the price of each item being ordered, hear the 
amount of sales tax included in the order, hear the total cost 
of the order before accepting. The caller can cancel the 
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. anv time and can choose the shipping method, based on 

ZZ::JsI:Z entered h. the use. o. based on an a..^^^^ 

- rairre rse-c.^^^^^^^^^^^^^ r-Un 

customer ^^^^^^J.^""^^ catalogue number item, at 

' rrfrthos;; oL:^^^ 'aving a description sheet available, 
least for those pro ^^^^ ^^^^^^^ ^^^^ ^3 

The system can collect the caller 

J ^r.Kii- card numbers, monthly bill or invux 
credit card, debit transmit to the 

like In some embodiments, the system 
the like, in so ^^^^eials" (audio or video) e.g., 

t^s P.oviaea. .n«™a.i<.„ sue. « ---"on 

software, "-^^^^^^^^f/^^C: Operator . prsfer..ly the syste. 
„.s„ ths "^^^//tnforBation which r.,y he of use to the 

will provide Items of inror» „„.„tor such as product 

customer in rh' wlt^ a reminder to 

T'tierrtrTo:; r;;ere items/'^roferahlv, automated 
Ters- as°c:rext-sensitive help is availahle to the user 

- "Tn-another 

aescrihed functions of providing ' „, .^vertisers of 

providing and P""-^"^^.--;"^;"^ Tco^^ated in a single 
" ngn: grer:ilV depict such a system, 

system. Figs. ^ ^ information 

™,en a new caller '^^Z^^*^ ,,thered 1104. 

regarding^the ^ " ^^^t over a modem connection. 

The system (e.g. , via P ^^^^^^ ^^^^ 

30 via voice over an IVR, or By^ P caller wishes to use. If 
caller has an agent numher that -Ue/;^ , 

net, the caller ^^^J^^^^^ caller can then 

agent, using a procedure descrio 

select among a number of options. The caller c , 
select am g -uch as requesting coupons for a 

35 coupon ih^c-^-" '",;;ertl^g transmission of a coupon 
particular product, requesT^iny 

^cxage defined by the caller's agent and the like 
described above. 
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The caller can order a catalogue, as described above 
1112 The caller can order a product from a catalogue 
previously received 1114, e.g., using a process described 
below. The caller can request an update on a previous request 
, Bade by the caller, such as by activating an agent to search 
the product database for items of interest 1116. The caller 
can modify the portfolio he has previously defined for hxs 
agent 1118. For example, if the agent's portfolio previously 
included searching for database programs, the caller can 
modify the agent's portfolio to be directed to spreadsheet 
programs. The caller can ask to be connected to an operator 
1120 or ask for a direct connection to the seller (where 
available). In some systems, it may be useful to P-vxde a 
facility for connecting a caller to a client's (or seller s) 
operator or customer service representative, rather than to 
the system operator or representative. 

A number of items and services can be provided when 
a caller orders an item from a catalogue, using the 
interactive system. The system can check for -^^^^^ °/ 
coupons Which apply to the this item or which apply ^° -^^^^^ 
items and can inform or transmit the coupons to the caller, as 
described 1202 (Fig. 12). The system can check for the 
existence of a customer account number, and verify with the 
caller that the information (e.g., shipping address, credit 
card information) is still valid 1206. The system can verify 
that the item being purchased is compatible with equipment 
owned or recently purchased by the caller (e.g., to verify 
software compatibility with a recently-purchased computer 
system) . The system can determine if the product is being 
purchased as a gift 1208. In this case, the shipping 
information for the gift is obtained. The caller <^--^- 
offered the opportunity to include a virtual gift card with 
the gift 1212. A virtual gift card is an audio video or text 
message recorded by the gift-giver and stored for later 
playback. In one embodiment, the gift is packaged with 
instructions to the recipient regarding how to call up and 
receive the recorded voice message. Typically, the message 
will be recorded in a system similar to a voice-mail system 
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and playbaclc will be Initiatea by the recipient ""^"9 ^ 
TetepnoL nu^r and enterin, a playback cede. ^^^"^"^^^^ 
.essL will be retained on the system fcr a period of time 

InUlal Playba* and thereafter erased to ...e room for 

, other ^„^,,,„ ,i,Un, information is 

then used for processin, the order. The order can be sent to 
a Shipping department or directly to the manufacturer for a 
L^^ship procedure. In some cases, it may be preferable for 
0 Te s^stL to communicate directly -1th a client-s or seller's 
olr-fulfUlment department or database. In such a system 

database may be modified or updated by the system in «e 
same way as the database would be m^ified 
purchased directly from the manufacturer or retailer. Thus 
,S the order fulfillment personnel can fill '^^^^^ ^^^VT^^ 
database, regardless of whether the order ^-^^^^^J" 
manufacturer or retailer or via the system of the present 
re"i:r However, the order is placed -^-out -e nee^ 
additional effort or manual input by the personnel of the 
-in -rptailer OX* manufacturer. 

20 retailer 3,3^^ can be used for customer 

plclc-up rather than for shipping (e.g., to reserve a rental 
vWeo, or to verify the status of goods or services ordered 
; g. to ingulre whether dry cleaning is ready for plcKup). 
« « 111 these cases, the information or services provided to 

^^e ire^"lthout the need for the retailer to hire personnel 
Tpe^form this function, without the need for the 
aevelop his own automated system for providing the service and 
with a lower potential for error. The manufacturer can be 
,„ provided with paocaglng information Including -^o™^"" 

regarding Items to be included in the shipment such as the 
coupons Identified in step 1202, or the virtual gift card 
information from step 1212. Recorded message information 
other than virtual gift cards can also be included For 
35 e^le, the manufacturer may specify that the product is to 

r^cco;panied by instructions telling the buyer how to acc^s 
recorded messages (or an IVR system, to assist in such matters 
as product set-up, installation, unpacking, product 
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infcrMatlcn ".'-^^--'^ u^at. inventory data 

provided to shipping can also be usea to up 

, The purchase ot a product can be used to establish 

ti.es for £ollow-up transmissions, such as call-bao. to the 
! I 1222 e g. , to offer extended service or warranty 

""Hts r"lted pUcts, coupons, updates, and the liKe. 
p^.ucts, related^P ^^.^^ 

tnls option 1226. The buyer can get information on related 
;Lucts or catalogues 1228. The buyer can be ^^tu- d to the 

• ™.nu (Fia 11) to initiate another transaction 1230. 
roaxn menu (Fig. H) indicates a 

AS depicted in Fig. 13, " 
' desire to establish a ne. agent, initial information regarding 
the na.e and address of the caller is obtained 1302 » 
desired, this information can be checKed against "^^^^^^ 
dliabascs to determine if this caller has already established 
2« rfearone agent 130,. In some cases, it may be desirable 
to limit the number of agents any one user can create. In^ 
t^e cases, the database is cheCed to see if ™ 
^ Of agents has been exceeded 130.. If so. the caller is 
informed that he may either modify an existing agent, or exi 
25 the system 1308. If not. the caller is asKed whether he 

wishrto modify an old agent (as described below, or create a 
"Regent 1310. If a ne. agent is being created, 
rl^arling the caller, s shipping, billing 

prLerences is gathered 1312, either from --""'^^^^^^^ 
30 information relating to this caller (which the ^^^^ 

verify at this time,, or from caller input (e.g., using an 
IVR, input from a PC, connected via a modem, or by 
int;rvention of an operator, . The system also gathers 
■ information regarding the portfolio which is ^esired for the 
36 new agent. This procedure is similar the that used for 

modifying an existing agent. Different embod-ents of the 
invention can be used to provide systems which give the 
^IThaser or user of this system greater or lesser control 



PCT/US93/12540 

WO 94/15294 

53 

over interaction with the system. For example, in one 
embodiment, the system can be configured to place calls or 
other communication to the user at times determined by the 
system in accordance with various criteria (either to maximize 
5 convenience to the user or to maximize, for example, sales) . 
m other embodiment, the system can be configured such that 
the user can optionally block all responses or callbacks untxl 
such time as the user requests responses or callbacks. 

As depicted in Fig. 14, when an existing agent is 
10 modified, there are a number of agent attributes which can be 
reviewed and/or modified. The types of attributes an agent 
May have depends largely on the purpose of the interactive 
system. For example, if the interactive system is configured 
to create personalized catalogues of the products of a single 
15 retail outlet, the attributes will relate only to the type of 
products carried by the retail outlet (in the case of a 
software seller, for example, type of application, price, 
features, type of computer used by the buyer, etc). On the 
other hand, if the interactive system is configured to create 
20 personalized catalogues of products from a number of diverse 
manufacturers, the agent might have a number of further 
attributes (e.g., preference for a particular manufacturer, 
category of product, such as software, computer systems, 
peripherals, or accessories) . 
25 TO modify an existing agent, the agent identifier or 

number is obtained 1402 and the procedure loops through 1404, 
1406 all attributes of the agent, playing-back the current 
attribute 1408, and prompting the user to confirm this 
attribute or to select a new choice for this attribute, e.g., 

30 from among a menu 1410. 

" " Although the invention has been described by way of 

a preferred embodiment and certain variations and 
modifications, other variations, modifications and embodiments 
can also be used, the invention being defined by the following 

35 claims. 
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a p^T TR CL ^TMRD IS: 

1 An interactive computing system for routing 
information" between a plurality of data nodes and a plurality 
5 of information processing applications, comprising: 

a plurality of generic I/O interface means for 
receiving I/O data from and transmitting I/O data to said 
plurality of data nodes, each of said nodes receiving and 
transmitting said I/O data according to a data protocol, saxd 
10 I/O data including a data processing request, each of said 

generic I/O interface means converting said I/O data to a form 
for receiving and transmitting according to a generic I/O 
protocol, at least a first of said generic I/O interface means 
configured to conduct communication with first and second data 
15 nodes, according to first and second protocols, respectively, 
said first and second protocols being different from one 
another; 

a plurality of generic application interface means 
for receiving application data from and transmitting 
20 application data to said plurality of information processing 

applications, each of said plurality of information processing 
applications receiving and transmitting said application data 
according to a data protocol, each of said generic application 
interface means converting said application data to a from for 
25 receiving and transmitting according to a generic application 
protocol, at least a first of said generic application 
interface means configured to conduct communication with first 
and second information processing applications according to 
third and fourth protocols, respectively, said third and 
30 fourth protocols being different from one another; and 

a computing means, coupled to said plurality of 
generic I/O interface means and to said plurality of generic 
application interface means, for receiving and evaluating at 
least some of said I/O data to select one of said plurality of 
35 data processing applications to process said I/O data. 

2. An interactive computer system, as claimed in 
claim 1, Wherein at least a first of said data nodes is 
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. . r,o«nit a user to input a request and wherein 

= r;ur„ indorsation Via saia n.s. o. sa.a 
data nodes. 

3 A method for routing information between a 

0 Plurality oi data nodes and a plurality of information 

Leivin, 1,0 -a .rom .a^^Xu^^^^^^^^^^^ 
into said plurality of ,ener.o "/"^^^^^^^ ^.^..^^^ 

" r/0 data from 'f^J-^-J^OTrd ™^^^ 'aid 1/0 
^ta ■'=*-'"''"f;tr" plurality of data protocols, said 

roVarirud-Za'di:: - r 

,«,eri= I/O interfaces converting =a.d ^'^^^^^^ 
" Leiving and transmitt^g -;-ne^:rL':^ri:t::faces 
protocol, at least a first or sa y 

-""-io::irgtni::ra::te~r^^^^^^^ 

:::r;i::m::n: protocols .ein, different fro. one 
" another; ^^^^^^^^ ^ ^^^^^^^^^ ^^^^.^ application 

'"'"'""';„viding a routing computer, operating according to 
^ n'^JucUion data from said plurality of 

generic apricatio! -^^r s"" ^i^ 0::^:^^ 
"iHl^Stron:::!::: — appli'cations. eacn Of 

Tail :raut: Of -rp:rirtira:: — , to 

" receiving ^ — rfrirgerrrap:ii=ation interfaces 
a data protocol, each or y ^ receiving and 

—ri^ntrirra rert: tppiicatlon protocol, at 
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least a first of said generic application interfaces 
configured to conduct communication with first and second 
information processing applications according to third and 
fourth protocols, respectively, said third and fourth 
protocols being different from one another; and 

receiving and evaluating, in said routing computer, 
at least some of said I/O data to select one of said plurality 
of data processing applications to process said I/O data. 

4. A method, as claimed in claim 3, further 
comprising:^ ^^^^ an additional data node to a first of said 
plurality of generic I/O interfaces, said ^^^'^'^^^^ ^^^J^^^ 
receiving and transmitting data according to an addxtxonal 
protocol different from any of said first plurality of 

■ protocols ; ^ j. 

modifying said first generic I/O interface to 

convert I/O data provided from said additional node in said 
additional protocol to a form for receiving and transmitting 
according to a generic I/O protocol; and 

receiving and evaluating, in said routing computer, 
at least some of said I/O data transmitted from said 
additional node, substantially without modification of said 
routing computer or said routing computer program. 

5. A telecommunications management system 

comprising: _ 

means for receiving telecommunications calls, ana 

for placing a plurality of received calls, intended for a busy 
facility, on hold, each of said plurality of calls being 
assigned a place in a queue, wherein at least . first call, 
placed in said queue at a first time, will normally be 
connected to said facility before a second call which was 
placed in said queue at a time after said first time; 

means for at least partially servicing at least said 
first call by an automatic processing means, without said 
first call losing its place in said queue. 
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6. 



A telecommunications management system, as 
claimed in claim 5, wherein said automatic processing means 
includes at least one of a means for supplying retail 
locations and hours, means for automated ordering of goods and 
services and means for playing music. 

7. A telecommunications management system, as 
claimed in claim 6, wherein said means for playing music 
permits a user to select among a plurality of types of musxc, 
or to select silence. 



8. An interactive computer system comprising: 
mlans for interfacing with input received from and 

output sent to a user of the system; 

means for storing information regarding a plurality 
of products and services, including information regarding the 
time of availability of such products and services; 

means for receiving, via said means for interfacing, 
an identification of one of said plurality of products and 

20 services; and 

means for outputting said information regarding time 

of availability with respect to said identified one of said 
products and services. 

25 9. An interactive computer system comprising; 

means for interfacing with input received from and 
output sent to a user of the system. 

means for storing information about a plurality of 
orders for goods and services, including information regarding 
30 the time .of shipment of an order for such goods and services; 

means for receiving, via said means for interfacing, 
an identification of one of said plurality of orders for goods 

and services; and 

means for outputting said information regarding time 
35 of shipment with respect to said identified one of said goods 
and services. 
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10 An interactive computer system comprising: 
means for interfacing with input received from and 
output sent to a user of the system; 

means for storing information about a plurality of 

locations of product outlets; ^ 

means for receiving, via said means for interfacing, 

an identification of a first location; and 

means for automatically outputting the location of 
at least one of said product outlets which is in a 
predetermined spatial relationship to said first location. 

11 An interactive computer system, as claimed in 
Claim 10, Wherein said predetermined spatial relationship 
defines those product outlets within a predetermined maximum 
distance from said first location. 

12 An interactive computer system, as claimed in 
claim 10, Wherein said predetermined spatial relationship 
defines the product outlet closest to said first location. 

13. A method for providing classified ad 
information to a individual, comprising: 

providing data processor means, including a memory 
and a telecommunications switch; 

storing, in said memory, an ad database comprising a 
plurality of ads, each ad comprising data in fields describing 
an item available throughout the system, at least some of said 
plurality of ads including recorded audio or video messages 
stored in said data processor means via said 
30 telecommunications switch, a unique ad number being assigned 

to each ad; 

receiving telephone calls, using said 
telecommunications switch, from an individual desiring to 
Obtain information about a specific item available through the 
35 system; 

identifying an ad in said ad database, using 
information provided by said individual; 



PCTrtJS93/12540 

WO M/1S2M 

59 

asseBbling an output message conveying at least some 
aata in the fields of the identified ad, and includxng one of 
said recorded audio or video messages. 



14. 



A computer based classified ad system, the 



system comprising: 

data processing means including: 

means for creating an ad database 
comprising a plurality of ads, each ad 
comprising data, provided by a seller 
describing an item to be made available; 

means for receiving profile data 
describing an item sought from at least firs 
and second prospective purchasers, 

means, coupled to said means for creating 
and to said means for receiving profile data, 
for comparing the profile data to the ads xn 
the ad database to determine if any of the ads 
match the profile data and, if so, for 
generating output comprising the ads that match 

the profile; and 

means, coupled to said means for 
comparing, for compiling and storing statistics 
relating to said ads, said statistics including 
at least an indication of how many matches have 
been found with said ads; 
an interactive response system, coupled to said data 

processing means, including 

means for outputting at least a first 
output message to said first prospective 
^° purchaser, said output message including 

information from said ad database for ads that 
match the profile data for said first 
prospective purchaser; and 

means for outputting at least a second 
output message to said seller, said second 
output message including at least a portion of 
said statistics. 
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